// 入口函数
$(function () {
    // 需求1  点击a链接 显示隐藏
    $('#loginBox a').on('click', function () {
        // 显示注册区域 隐藏登录区域
        $('#regBox').show()
        $('#loginBox').hide()
    })

    $('#regBox a').on('click', function () {
        // 显示登录区域 隐藏注册区域
        $('#loginBox').show()
        $('#regBox').hide()
    })


    // 需求2 自定义校验规则
    let form = layui.form
    form.verify({
        username: [
            /^[\S]{1,10}$/,
            '用户必须1到10位,且不能出现空格'
        ],
        pwd: [
            /^[\S]{6,15}$/,
            '用户必须到6到15位,且不能出现空格'
        ],
        // 确认密码规则
        rePwd: function (value) {
            let pwd = $("#regBox [name=password]").val()
            if (pwd !== value) {
                return '两次密码输入不一致'
            }
        }
    })

    // 需求3 注册功能
    let layer = layui.layer
    $('#formReg').on('submit', function (e) {
        // 阻止表单默认提交
        e.preventDefault()
        // 发送axios
        axios({
            method: 'POST',
            url: '/api/reguser',
            data: $(this).serialize()// serialize 收集带有name属性 input里面的文本类型  收集数据
        }).then(function (res) {
            if (res.data.status !== 0) {
                return layer.msg(res.data.message)
            }
            // 成功
            layer.msg(res.data.message)
            // 切换到登录模块
            $('#regBox a').click()
            $('#formReg')[0].reset()
        })
    })


    // 需求4 登录功能
    $('#formLogin').on('submit', function (e) {
        // 阻止表单默认提交
        e.preventDefault()
        // 发送axios
        axios({
            method: 'POST',
            url: '/api/login',
            data: $(this).serialize()// serialize 收集带有name属性 input里面的文本类型  收集数据
        }).then(function (res) {
            if (res.data.status !== 0) {
                return layer.msg(res.data.message)
            }
            // 成功
            layer.msg(res.data.message)
            // 切换到登录模块
            //    成功 储存token
            localStorage.setItem('token', res.data.token)
            location.href = '/index.html'
        })
    })


})